## The instruction set of Intel® 8080 / 8085 microprocessors

```
One byte transfers
                                                      Two bytes transfers
MOV R1, R2.
                     R1 \leftarrow R2.
                                                      LXI RP, D16.
                                                                            RPL \leftarrow D16L, RPH \leftarrow D16H.
MOV R, M.
                      R \leftarrow M[HL].
                                                      SHLD ADR.
                                                                             M[ADR] \leftarrow L, M[ADR+1] \leftarrow H.
MOV M. R.
                      M[HL] \leftarrow R.
                                                                            L \leftarrow M[ADR], H \leftarrow M[ADR+1].
M[SP - 1] \leftarrow RPH, M[SP - 2] \leftarrow RPL, SP \leftarrow SP - 2.
                                                      LHLD ADR.
MVI R, D8.
                      R \leftarrow D8.
                                                      PUSH RP.
                                                                            M[SP-1] \leftarrow A, M[SP-2] \leftarrow F, SP \leftarrow SP-2.

RPL \leftarrow M[SP], RPH \leftarrow M[SP+1], SP \leftarrow SP+2.
                      M[HL] \leftarrow D8.
MVI M. D8.
                                                      PUSH PSW.
STAX RP.
                      M[RP] \leftarrow A.
                                                      POP RP.
                                                      POP PSW.*
LDAX RP.
                      A \leftarrow M[RP].
                                                                             F \leftarrow M[SP], A \leftarrow M[SP + 1], SP \leftarrow SP + 2.
                                                                             SP \leftarrow HL.
STA ADR.
                      M[ADR] \leftarrow A.
                                                      SPHL.
                      A \leftarrow M[ADR].
LDA ADR.
                                                      Exchange of bytes
Input and output instructions
                                                                     H \leftrightarrow D, L \leftrightarrow E.
                                                      XCHG.
                      A \leftarrow PORT.
IN PORT.
                                                      XTHL.
                                                                     L \leftrightarrow M[SP], H \leftrightarrow M[SP + 1].
OUT PORT.
                      PORT \leftarrow A.
Arithmetic and logic instructions with one operand
8-bit instructions
CMC.** CY \leftarrow \neg CY.
                                     INR R.***
                                                                                                Decimal adjust
                                                           R \leftarrow R + 1.
STC.**
              CY \leftarrow 1.
                                     DCR R.***
                                                           R \leftarrow R - 1.
                                     INR M.***
                                                           M[HL] \leftarrow M[HL] + 1.
               A \leftarrow \neg A.
                                                                                                DAA.*
                                                                                                               If A_{3-0} > 9 or AC = 1,
CMA.
                                     DCR M.***
                                                           M[HL] \leftarrow M[HL] - 1.
                                                                                                               then A_{3-0} \leftarrow A_{3-0} + 6;
                                                           RP \leftarrow RP + 1.
                                                                                                               if A_{7-4} > 9 or CY = 1,
                                     INX RP.
                                     DCX RP.
                                                           RP \leftarrow RP - 1.
                                                                                                               then A_{7-4} \leftarrow A_{7-4} + 6.
Arithmetic and logic instructions with two operands
8-bit instructions
ADD R.*
                                                                                                        ADD M.*
                A \leftarrow A + R.
                                                  ADI D8.*
                                                                   A \leftarrow A + D8.
                                                                                                                         A \leftarrow A + M[HL].
ADC R.*
                A \leftarrow A + R + CY.
                                                  ACI D8.*
                                                                  A \leftarrow A + D8 + CY.
                                                                                                        ADC M.*
                                                                                                                         A \leftarrow A + M[HL] + CY.
SUB R.*
                                                  SUI D8.*
                                                                                                        SUB M.*
                A \leftarrow A - R.
                                                                   A \leftarrow A - D8.
                                                                                                                         A \leftarrow A - M[HL].
SBB R.*
                A \leftarrow A - (R + CY).
                                                  SBI D8.*
                                                                   A \leftarrow A - (D8 + CY).
                                                                                                       SBB M.*
                                                                                                                         A \leftarrow A - (M[HL] + CY).
                                                  ANI D8.*
                                                                                                        ANA M.*
                A \leftarrow A \wedge R.
ANA R.*
                                                                   A \leftarrow A \land D8.
                                                                                                                         A \leftarrow A \land M[HL].
ORA R.*
                                                  ORI D8.*
                                                                                                        ORA M.*
                A \leftarrow A \lor R.
                                                                   A \leftarrow A \lor D8.
                                                                                                                         A \leftarrow A \vee M[HL].
XRA R.*
                A \leftarrow A \ \forall \, R.
                                                  XRI D8.*
                                                                                                        XRA M.*
                                                                   A \leftarrow A \forall D8.
                                                                                                                         A \leftarrow A \forall M[HL].
CMP R.*
                A - R.
                                            Accumulator content rotation instructions
                A - M[HL].
CMP M.*
CPI D8.*
                A - D8.
                                            RLC.** A_{n+1} \leftarrow A_n, n = 0-6, A_0 \leftarrow A_7, CY \leftarrow A_7. Rotate to left.
                                           RRC.** A_n \leftarrow A_{n+1}, n = 0-6, A_0 \leftarrow A_7, CY \leftarrow A_0. Rotate to right.

RRC.** A_n \leftarrow A_{n+1}, n = 0-6, A_7 \leftarrow A_0, CY \leftarrow A_0. Rotate to right.

RAL.** A_{n+1} \leftarrow A_n, n = 0-6, A_0 \leftarrow CY, CY \leftarrow A_7. Rotate left through carry flag CY.

RAR.** A_n \leftarrow A_{n+1}, n = 0-6, A_7 \leftarrow CY, CY \leftarrow A_0. Rotate right through carry flag CY.
16-bit instructions
DAD RP.** HL \leftarrow HL + RP.
Branch instructions
                                                                    Call to subroutine and return from subroutine instructions
                                                                                        M[SP] \leftarrow PC + 3, SP \leftarrow SP - 2, PC \leftarrow ADR.
PCHL.
                       PC \leftarrow HL.
                                                                    CALL ADR.
JMP ADR.
                       PC \leftarrow M[ADR].
                                                                                        M[SP] \leftarrow PC + 3, SP \leftarrow SP - 2, PC \leftarrow ADR.
                                                                    Ccc ADR.
                       PC \leftarrow M[ADR].
Jcc ADR.
                                                                    RST N.
                                                                                        PC \leftarrow 8 \times N \ (N = 0, 1, ..., 7). \ 8 \times N = ADR.
                                                                                        ADR = 0_{16}, 8_{16}, 10_{16}, 18_{16}, 20_{16}, 28_{16}, 30_{16}, 38_{16}.
                                                                                        PC \leftarrow M[SP], SP \leftarrow SP + 2.

PC \leftarrow M[SP], SP \leftarrow SP + 2.
                                                                    RET.
Microprocessor control instructions
                                                                    Rcc.
EI
          Enable interrupts.
                                                                    Format of flags register F
DI
          Disable interrupts.
HLT
          Halt.
                                                                    D7 D6 D5 D4 D3 D2 D1 D0
         PC \leftarrow PC + 1. No operation.
NOP
                                                                                0 AC 0
```

## Notes:

- \* instruction affects all flags.
- \*\* instruction affects only flag CY.
- \*\*\* instruction affects all flags except CY.
- R, R1, R2 the contents of registers A, B, C, D, E, H or L (8-bits);
- **M** memory location, whose address is in register pair **HL**;
- M[HL] content of the memory location, whose address is in register pair HL (8-bits);
- **D8** 8-bit immediate data or direct operand (second byte of the instruction);
- **D16** 16-bit immediate data or direct operand (second and third byte of the instruction);
- D16L and D16H lower and higher byte of 16-bit immediate data or direct operand;

**ADR** – 16-bit address of memory location (second and third byte of the instruction);

M[ADR] – content of the memory location, whose address is specified in second and third byte of the instruction (8-bits):

**RP** – register pair **BC**, **DE**, **HL** or content of stack pointer **SP** (16-bits);

**RPL** and **RPH** – low and high order register of register pair;

M[RP] – content of the memory location, whose address is in register pair BC or DE (8-bits);

M[SP] - stack;

**SP** – 16-bit stack pointer;

**PC** – 16-bit program counter;

**PSW** – 16-bit processor status word (contents of register **A** and flags register **F**);

**PORT** – 8-bit number (address) of input or output port (second byte of the instruction);

N – interrupt maintenance subroutine number;

**n** – bit number (bits are numbered from right to left from 0 to 7);

cc – branch condition (must be replaced by NZ, Z, NC, C, PO, PE, P or M);

CY – carry bit of flags register F;

 $\mathbf{P}$  – parity bit of flags register  $\mathbf{F}$ ;

**AC** – auxiliary carry bit of flags register **F**;

 $\mathbf{Z}$  – zero bit of flags register  $\mathbf{F}$ ;

S – sign bit of flags register F;

 $\wedge$  – logical AND;

∨ – logical inclusive OR;

 $\forall$  – logical exclusive OR;

 $\neg$  – complement;

 $\leftarrow$  – transfer;

 $\leftrightarrow$  – exchange.

## The instructions hexadecimal codes of Intel® 8080 / 8085 microprocessors

|   | 0                | 1              | 2           | 3           | 4           | 5           | 6            | 7           | 8           | 9           | A           | В           | C           | D           | E            | F           |   |
|---|------------------|----------------|-------------|-------------|-------------|-------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|--------------|-------------|---|
| 0 | NOP              | LXI<br>B, D16  | STAX<br>B   | INX B       | INR B       | DCR B       | MVI<br>B, D8 | RLC         | ı           | DAD B       | LDAX<br>B   | DCX B       | INR C       | DCR C       | MVI<br>C, D8 | RRC         | 0 |
| 1 | _                | LXI<br>D, D16  | STAX<br>D   | INX D       | INR D       | DCR D       | MVI<br>D, D8 | RAL         | I           | DAD D       | LDAX<br>D   | DCX D       | INR E       | DCR E       | MVI<br>E, D8 | RAR         | 1 |
| 2 | RIM <sup>1</sup> | LXI<br>H, D16  | SHLD<br>ADR | INX H       | INR H       | DCR H       | MVI<br>H, D8 | DAA         | ı           | DAD H       | LHLD<br>ADR | DCX H       | INR L       | DCR L       | MVI<br>L, D8 | CMA         | 2 |
| 3 | SIM <sup>1</sup> | LXI SP,<br>D16 | STA<br>ADR  | INX SP      | INR M       | DCR M       | MVI<br>M, D8 | STC         | I           | DAD<br>SP   | LDA<br>ADR  | DCX SP      | INR A       | DCR A       | MVI<br>A, D8 | СМС         | 3 |
| 4 | MOV<br>B, B      | MOV<br>B, C    | MOV<br>B, D | MOV<br>B, E | MOV<br>B, H | MOV<br>B, L | MOV<br>B, M  | MOV<br>B, A | MOV<br>C, B | MOV<br>C, C | MOV<br>C, D | MOV<br>C, E | MOV<br>C, H | MOV<br>C, L | MOV<br>C, M  | MOV<br>C, A | 4 |
| 5 | MOV<br>D, B      | MOV<br>D, C    | MOV<br>D, D | MOV<br>D, E | MOV<br>D, H | MOV<br>D, L | MOV<br>D, M  | MOV<br>D, A | MOV<br>E, B | MOV<br>E, C | MOV<br>E, D | MOV<br>E, E | MOV<br>E, H | MOV<br>E, L | MOV<br>E, M  | MOV<br>E, A | 5 |
| 6 | MOV<br>H, B      | MOV<br>H, C    | MOV<br>H, D | MOV<br>H, E | MOV<br>H, H | MOV<br>H, L | MOV<br>H, M  | MOV<br>H, A | MOV<br>L, B | MOV<br>L, C | MOV<br>L, D | MOV<br>L, E | MOV<br>L, H | MOV<br>L, L | MOV<br>L, M  | MOV<br>L, A | 6 |
| 7 | MOV<br>M, B      | MOV<br>M, C    | MOV<br>M, D | MOV<br>M, E | MOV<br>M, H | MOV<br>M, L | HLT          | MOV<br>M, A | MOV<br>A, B | MOV<br>A, C | MOV<br>A, D | MOV<br>A, E | MOV<br>A, H | MOV<br>A, L | MOV<br>A, M  | MOV<br>A, A | 7 |
| 8 | ADD B            | ADD C          | ADD D       | ADD E       | ADD H       | ADD L       | ADD M        | ADD A       | ADC B       | ADC C       | ADC D       | ADC E       | ADC H       | ADC L       | ADC M        | ADC A       | 8 |
| 9 | SUB B            | SUB C          | SUB D       | SUB E       | SUB H       | SUB L       | SUB M        | SUB A       | SBB B       | SBB C       | SBB D       | SBB E       | SBB H       | SBB L       | SBB M        | SBB A       | 9 |
| A | ANA B            | ANA C          | ANA D       | ANA E       | ANA H       | ANA L       | ANA M        | ANA A       | XRA B       | XRA C       | XRA D       | XRA E       | XRA H       | XRA L       | XRA M        | XRA A       | A |
| В | ORA B            | ORA C          | ORA D       | ORA E       | ORA H       | ORA L       | ORA M        | ORA A       | CMP B       | CMP C       | CMP D       | CMP E       | СМР Н       | CMP L       | СМР М        | CMP A       | В |
| С | RNZ              | POP B          | JNZ<br>ADR  | JMP<br>ADR  | CNZ<br>ADR  | PUSH<br>B   | ADI<br>D8    | RST 0       | RZ          | RET         | JZ<br>ADR   |             | CZ<br>ADR   | CALL<br>ADR | ACI<br>D8    | RST 1       | С |
| D | RNC              | POP D          | JNC<br>ADR  | OUT<br>PORT | CNC<br>ADR  | PUSH<br>D   | SUI<br>D8    | RST 2       | RC          | _           | JC<br>ADR   | IN<br>PORT  | CC<br>ADR   | _           | SBI<br>D8    | RST 3       | D |
| E | RPO              | РОР Н          | JPO<br>ADR  | XTHL        | CPO<br>ADR  | PUSH<br>H   | ANI<br>D8    | RST 4       | RPE         | PCHL        | JPE<br>ADR  | XCHG        | CPE<br>ADR  | -           | XRI<br>D8    | RST 5       | E |
| F | RP               | POP<br>PSW     | JP<br>ADR   | DI          | CP<br>ADR   | PUSH<br>PSW | ORI<br>D8    | RST 6       | RM          | SPHL        | JM<br>ADR   | EI          | CM<br>ADR   | -           | CPI<br>D8    | RST 7       | F |
|   | 0                | 1              | 2           | 3           | 4           | 5           | 6            | 7           | 8           | 9           | A           | В           | C           | D           | E            | F           |   |

<sup>&</sup>lt;sup>1</sup> Instruction is only supported on the Intel<sup>®</sup> 8085 microprocessor.